

Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

|          |          | •        |                |                                 |
|----------|----------|----------|----------------|---------------------------------|
| Sem:     | 4TH      | Section: | IT7, IT8       | Faculty: Prof. Anil Kumar Swain |
| DOA: Dt. | 03.02.20 | 20       |                | DOS:Dt.14.02.2020               |
| Roll Nu  | mber     |          | Full Signature |                                 |

Instruction: Answer all questions.

### 1. What is Stored Program Concept?

#### Answer:

All modern computers use the stored program concept which was initially conceived by the design team of ISA computer led by Von Neumann. Hence, it is commonly known as **Von Neumann** concept. The essentials of stored program concept are as follows:

- The computer has five different types of units: memory, ALU, control unit, input unit and output unit.
- The program and data are stored in a common memory.
- Once a program is in memory, the computer can execute it automatically without manual intervention.
- The control unit fetches and executes the instructions in sequence one by one. This sequential execution can be modified by certain type of instructions.
- An instruction can modify the contents of any location in memory. Hence, a program can modify itself; instruction-execution sequence also can be modified.

N.B: A computer with a **von Neumann architecture** stores program data and instruction data in the same memory; a computer with a **Harvard architecture** has separate memories for storing program and data.

### 2. What are the functionalities of MAR, MDR, IR, PC, SP and GPRs?

#### Answers

Refer page no.8 or 412 of CO Book by Carl Hammacher, 5th ed.

# 3. What is the difference between word addressable and byte addressable memory? Answer:

|    | Byte Addressable Memory                                                                                                             | Word Addressable Memory                                                                                                                                      |
|----|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| a) | Byte addressable memory refers to memory address that is accessed one byte at a time. i.e. Here byte is fixed that is 8 bit always. | a) Word addressable memory refers to memory address that is accessed one word at a time. ie. Here word is not fixed that typically range from 16 to 64 bits. |
| b) | Individual byte has a unique address.                                                                                               | b) Individual Word has a unique address.                                                                                                                     |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020

DOS:Dt.14.02.2020

4. What is difference between Big Endian and Little Endian byte order.

#### **Answer:**

- Little and big endian are two ways of storing multibyte data-types (int, float, etc).
- In byte ordering, the "big end" byte is called the "high-order byte" or the "most significant byte".
- The term 'endian' as derived from 'end' may lead to confusion. The end denotes which end of the number comes first rather than which part comes at the end of the sequence of bytes. The basic endian layout can be seen in the table below:

| Endianness | First Byte        | Last Byte         |  |
|------------|-------------------|-------------------|--|
| Big        | Most Significant  | Least Significant |  |
| Little     | Least Significant | Most Significant  |  |

| Big Endian Byte Order                                                                                                                                                                                                                         | Little Endian Byte Order                                                                                                                                                                                                |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <ul> <li>a) The most significant byte (the "big end") of the data is placed at the byte with the lowest address. The rest of the data is placed in order in the next bytes in memory.</li> <li>Example: Macintosh Computer/Machine</li> </ul> | a) The least significant byte (the "little end") of the data is placed at the byte with the lowest address. The rest of the data is placed in order in the next bytes in memory.  Example: Intel 80x86 Computer/Machine |  |  |

**Example:** Represent the integer ox01234567 (represented in hexa) in Big Endian and Littel Endian machines.

#### **Answer:**



Little Endian

5. If a computer a runs a program in 10 seconds and B runs the same program in 15 seconds, how much faster is A than B?

#### Answer:

We know that A is n times faster than B if

$$\frac{\text{Performance of A}}{\text{Performance of B}} = \frac{\text{Execution Time for B}}{\text{Execution Time for A}} = n$$

=>15/10=1.5



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

A is therefore 1.5 times faster than B.

6. To maximize performance, we want to minimize response time or execution time for some task (True/ False).

**Answer:** 

True

7. Do the following changes to a computer system increase throughput, decrease response time or both?

Case1: Replacing the processor in a computer with a faster version.

Case2: Adding additional processors to a system that uses multiple processors for separate tasks. For example searching the world wide web.

#### **Answer:**

In case1: both response time and throughput are improved because decreasing response time almost always improves throughput. In case2: Only throughput increases because no one task gets work done faster.

8. A processor is advertised as having a speed of 2GHz. What 2GHz refers. Explain.

#### **Answer:**

2GHz referes to clock rate. This means that it can process data internally 2 billion times a second (every clock cycle). If the processor is a 32-bit processor running at 2GHz then it can potentially process 32 bits of data simultaneously, 2 billion times a second!!

9. Derive Basic Performance Equation.

#### Answer:

- We know, Response time or Execution time is the time taken by the computer, to execute a given program, from start to end of the program.
- There are **three** equally important components of execution time.
  - i) Clock cycle time/clock period It is just the length of a cycle.
  - ii) **CPI** It is is the average number of clock cycles per instruction, for a particular machine and program.
  - iii) Number of instructions in a program It is the dynamic instruction count that is how many instructions are actually executed when the program runs, not the static instruction count that is how many lines of code are in a program.
- The basic performance equation, which is fundamental to measuring computer performance, measures the CPU time, is as follows.
  - ✓ CPU Time To execute a program = T= time/program
  - $\checkmark$  Time require to execute a basic step = P = time/cycle
  - ✓ Average number of basic steps required to execute one machine instruction = CPI = S = cycles/instruction
  - ✓ Number of instructions a program contains is N = instructions/program Now



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

$$\frac{Time}{Program} = \frac{\underline{Time}}{\underline{Cycle}} \ x \ \frac{Cycles}{Instruction} \ x \ \frac{Instructions}{Program}$$

$$CPU Time = P x CPI x N$$

$$T = P \times S \times N$$

$$T = \frac{S \times N}{R}$$

Reference: CO/ Clarl Hamacher Book, 5<sup>th</sup> Ed/ Page-15 →





10. A processor advertised as having a 900 MHz clock is always provides better performance than a 700-MHz processor (True/False). Justify your answer.

**Answer:** 

False because both processors may have a different value of S.

11. When run on a given system, a program takes 1,000, 000 cycles. If the system achieves a CPI of 40, how many instructions were executed in running the program?

**Answer:** 

12. Given a binary pattern in some memory location, is it possible to tell whether this pattern represents a machine instruction or a number?

Answer:

No; any binary pattern can be interpreted as a number or as an instruction.

13. At the end of a memory read operation, the MDR is loaded with a binary combination, how that combination is interpreted as an instruction or an operand to an instruction?

Answer:

If the memory operation is initiated by sending the contents of PC to MAR, then the content of MDR will be interpreted as an instruction else as an operand.

- 14. The content of register R1 is 11010110. What will be the decimal value after execution of the following instructions. Assume the number is represented in 2's complement format.
  - a) RotateL #2, R1
  - b) RotateL #3, R1

**Answer:** 

a) RotateL #2, R1

After rotation R1's content will be 01011011



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

In Decimal the value =  $2^6 + 2^4 + 2^3 + 2^1 + 2^0 = 64 + 16 + 8 + 2 + 1 = 91$ 

b) RotateL #3, R1

After rotation R1's content will be 10110110

The number is -ve, so

In Decimal the value = -( 2's of 10110110)=

= -(01001010) =-(2<sup>6</sup> + 2<sup>3</sup> + 2<sup>1</sup>) = -(64 + 8 + 2) = -74

- 15. The content of register R1 is 10010110. What will be the decimal value after execution of the follwoing individual instructions. Assume the number is represented in 2's complement format.
  - a) LShiftL #2, R1
  - b) AShiftR +3, R1

**Answer:** 

a) LShiftL #2, R1

After logical left shift of R1 by 2 bits, R1's content will be 01011000

In Decimal the value =  $2^6 + 2^4 + 2^3 = 64 + 16 + 8 = 88$ 

b) AShiftR #3, R1

After aithmatic right shift of R1 by 3 bits, R1's content will be 11110010

The number is -ve, so

In Decimal the value = -(2's of  $\frac{11110010}{2}$ 

= -(00001110)=-(8 + 4 + 2) = -14

- 16. The content of register R2 (24 bit) is 10011000 10110011 11010111. Write the instruction for performing the following operations:
  - a) Clear the LSB of R2 to 0.
  - b) Clear the MSB of R2 to 0.
  - c) Clear the  $2^{nd}$  byte of R2 to 0.
  - d) Set the MSB of R2 to 1.
  - e) Set LSB of R2 to 1.
  - f) Clear all bits of R2

**Answer:** 

The binary number 10011000 10110011 11010111 in hexa is 98 B3 D7

a) Clear the LSB of R2 to 0

And #\$FFFF00, R2

b) Clear the MSB of R2 to 0

And #\$00FFFF, R2

c) Clear the  $2^{nd}$  byte of R2 to 0

And #\$FF00FF, R2

d) Set the MSB of R2 to 1

**Or** #\$FF0000, R2

e) Set LSB of R2 to 1

**Or** #\$0000FF, R2



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020

DOS:Dt.14.02.2020

f) Clear all bits of R2

Clear R2

17. A memory byte location contains the pattern 01000001. What does this pattern represent when interpreted as a binary number? What does it represent as an ASCII code? Answer:

The decimal equivalent of the binary  $00101100 = 2^{6} + 2^{0} = 64 + 1 = 65$ . The pattern represents 65 and the ASCII character 'A' it represents.

**Note: ASCII** stands for **American Standard Code for Information Interchange.** It is a code that uses seven bits for representing 128 English characters as numbers, with each letter assigned a number from 0 to 127. Computers can only understand numbers, so an ASCII code is the numerical representation of a character such as 'a' or '@' or an action of some sort (Enter key, Esc key etc).

**Extended ASCII** uses eight instead of seven bits, which adds 128 additional characters. This gives extended ASCII the ability for extra characters, such as special symbols, foreign language letters, and drawing characters etc.

**18.** An instruction is a 24 bit instruction. It is a byte addressable memory. The PC contains 300. Which one of the following is a legal PC value:

(a) 400 (b) 500 (c) 600 (d) 700

**Answer:** 

(c) 600

19. A processor has 40 distinct instructions and 24 general purpose registers. A 32-bit instruction word has an opcode, two register operands and an immediate operand. The number of bits available for the immediate operand field is \_\_\_\_\_\_.

**Answer:** 

16

6 bits are needed for 40 distinct instructions (because, 32 < 40 < 64)

5 bits are needed for 24 general purpose registers (because, 16 < 24 < 32) 32-bit instruction word has an opcode (6 bit), two register operands (total 10 bits) and an immediate operand (x bits). The number of bits available for the immediate operand field => x = 32 -



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

**Computer Organisation & Architecture Home Assignment Solution** 

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

# **Addressing Modes and Assemble Languages**

- 20. Write an assembly language program to derive the expression X = A\*B+C\*D
  - a) in a stack based computer with zero address instructions
  - b) In a acumulator based CPU with one address instuctions
  - c) In register based CPU with two address instructions
  - d) In register based CPU with three address instructions

#### **Answer:**

# X = A\*B+C\*D

### (with zero address instructions)

**Step-1:** Convert the expression X = A\*B+C\*D into postfix (RPN) form

X = A\*B+C\*D

= (AB\*) + C\*D

=(AB\*)+(CD\*)

= AB\*CD\*+ (Make the RPN bracket free)

1 2 34 5 67

**Step-2**: Write the assembly language

Now Taking symbols from left to right, if symbol is a operand write instruction to push the operand into the stack. If the symbol is an operator write the appropriate opcode. For + operator write ADD, for \* operator write MULT etc.

### Assembly language

1. PUSH A ;  $TOS \leftarrow [A]$ 

2. PUSH B ;  $TOS \leftarrow [B]$ 

3. MULT ;  $TOS \leftarrow [A] * [B]$ 

4. PUSH C ;  $TOS \leftarrow [C]$ 

5. PUSH D ;  $TOS \leftarrow [D]$ 

6. MULT ;  $TOS \leftarrow [C] * [D]$ 

7. ADD ;  $TOS \leftarrow [A] * [B] + [C] * [D]$ 

8. POP  $X : X \leftarrow [TOS]$ 

### $\mathbf{X} = \mathbf{A} * \mathbf{B} + \mathbf{C} * \mathbf{D}$

#### (with one address instructions)

| Assembly language | RTN                         |
|-------------------|-----------------------------|
| LOAD A            | $; AC \leftarrow [A]$       |
| MULT B            | $AC \leftarrow [AC] * [B]$  |
| STORE T           | $T \leftarrow [AC]$         |
| LOAD C            | $AC \leftarrow [C]$         |
| MULT D            | $AC \leftarrow [AC] * [D]$  |
| ADD T             | $AC \leftarrow [AC] + [T]$  |
| STORE X           | $X \leftarrow [AC]$         |
| STORE A           | $, \Lambda \leftarrow [AC]$ |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

$$X = A*B+C*D$$

### (with two address instructions)

| (with two address instructions) |                                                             |  |  |  |  |
|---------------------------------|-------------------------------------------------------------|--|--|--|--|
| Assembly language               | RTN                                                         |  |  |  |  |
| MOVE A, R1                      | $; R1 \leftarrow [A]$                                       |  |  |  |  |
| MULT B, R1                      | $; R1 \leftarrow [R1] * [B]$                                |  |  |  |  |
| MOVE C, R2                      | $; R2 \leftarrow [C]$                                       |  |  |  |  |
| MULT D, R2                      | $; R2 \leftarrow [R2] * [D]$                                |  |  |  |  |
| ADD R1, R2                      | $; R2 \leftarrow [R2] + [R1]$                               |  |  |  |  |
| MOVE R2, X                      | $X \leftarrow [R2]$                                         |  |  |  |  |
| N.B: Always try to store        | the result in a register.                                   |  |  |  |  |
| If two operands are allow       | wed as memory operands then we rewrite the above as follows |  |  |  |  |
| Assembly language               | RTN                                                         |  |  |  |  |
| MULT A, B                       | $; B \leftarrow [B] * [A]$                                  |  |  |  |  |
| MULT C, D                       | $; D \leftarrow [D] * [C]$                                  |  |  |  |  |
| ADD B, D                        | $; D \leftarrow [D] * [B]$                                  |  |  |  |  |
| MOVE D, X                       | $; X \leftarrow [D]$                                        |  |  |  |  |
|                                 |                                                             |  |  |  |  |

#### X = A\*B+C\*D

#### (with three address instructions)

# Assembly language RTN

 $\begin{array}{ll} \text{MULT A, B, R1} & ; \text{R1} \leftarrow [\text{A}] * [\text{B}] \\ \text{MULT C, D, R2} & ; \text{R2} \leftarrow [\text{C}] * [\text{D}] \\ \text{ADD R1, R2, X} & ; \text{X} \leftarrow [\text{R1}] + [\text{R2}] \end{array}$ 

- 21. Registers R1 and R2 of a computer contain the decimal values 1200 and 4600. What is the effective address of the memory operand in each of the following instructions?
  - a) Load 20(R1), R5
  - b) Move #3000, R5
  - c) Store R5, 30(R1,R2)
  - d) Add –(R2), R5
  - e) Subtract (R1)+, R5

[CO/Hamacher Book/5th Ed/Exercise/2.13/Page-100]

### **Answer:**

- a) 1220 (Explanation: R1=1200, 20(R1) = EA = [R1] + 20 = 1200 + 20 = 1220)
- b) Part of the instruction
- c) 5830 (**Explanation:** R1=1200, R2=4600, 30(R1, R2)=> **EA**=[R1] +[R2] + 30 = 1200 + 4600 + 30 = 5830)
- d) 4599 (Explanation: R2=4600, -(R2) => R2 = [R2] 1 = 4600 1 = 4599, EA = [R2] = 4599)
- e) 1200 (Explanation: R1=1200, (R2)+=>EA=[R2]=1200, R2=[R2]+1=1201)



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar

**SPRING 2020** COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Section: IT7. IT8 4TH Faculty: **Prof. Anil Kumar Swain** Sem:

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

N. B. If each memory word consumes 4 bytes and machine is byte addressable, then answer of

d) 4596 (Explanation: R2=4600, -(R2) => R2 = [R2] - 4 = 4600 -4 = 4596, EA = [R2] = 4596

e) 1200 (Explanation: R1=1200, (R2)+=>EA = [R2] = 1200, R2 = [R2] + 4 = 1204)

22. Both of the following statements cause the value 300 to be stored in location 1000, but at different times.

> **ORIGIN 1000** DATAWORD 300 and Move #300,1000

Explain the difference.

[CO/Hamacher Book/5th Ed/Exercise/2.16/Page-100]

#### Answer:

The assembler directives ORIGIN and DATAWORD cause the object pro gram memory image constructed by the assembler to indicate that 300 is to be placed at memory word location 1000 at the time the program is loaded into memory prior to execution.

The Move instruction places 300 into memory word location 1000 when the instruction is executed as part of a program.

# **Stack & Subroutine**

23. Suppose that a stack runs from location 2000 (BOTTOM) downto no further than location 1500 (TOP) and each stack word consumes 4 bytes and machine is byte addressable. The stack pointer is loaded initially with the address value 2004. Write a routine for both PUSH and POP operation.

#### **Answer:**

Name of

| Name of                                                                   | Asser                    | nble Language                      | Remarks/ Actions of Assemble instructions                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------|--------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Routine SAFEPUSH (If it allows auto increment/ decrement addressing mode) | Compare Branch ≤ 0  Move | #1500, SP FULLERROR NEWITEM, -(SP) | Check to see if the stack pointer contains an address value equals to or less than 1500. If it does, the stack is full. Branch to the routine FULLERROR for appropriate action.  Otherwise, decrement the stack pointer and push the element in memory location NEWITEM onto the stack. |
| Or                                                                        |                          |                                    |                                                                                                                                                                                                                                                                                         |
| Name of Routine                                                           | Asser                    | nble Language                      | Remarks/ Actions of Assemble instructions                                                                                                                                                                                                                                               |
| SAFEPUSH<br>(If it does not<br>allow auto<br>increment/                   | Compare<br>Branch ≤ 0    | #1500, SP<br>FULLERROR             | Check to see if the stack pointer contains an address value equals to or less than 1500. If it does, the stack is full. Branch to the routine FULLERROR for appropriate action.                                                                                                         |
| decrement<br>addressing<br>mode)                                          | Sub<br>Move              | #4, SP<br>NEWITEM, (SP)            | Otherwise, decrement the stack pointer (SP) appropriately and push the element in memory location NEWITEM onto the stack.                                                                                                                                                               |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

| • | • | ٠ |  |
|---|---|---|--|

| Name of Routine                                       | Asse                   | mble Language                         | Remarks/ Actions of Assemble instructions                                                                                                                                                                              |
|-------------------------------------------------------|------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SAFEPOP</b>                                        | Compare                | #2000, SP                             | Check to see if the stack pointer contains an                                                                                                                                                                          |
| (If it allows                                         | Branch $> 0$           | EMPTYERROR                            | address value greater than 2000. If it does, the                                                                                                                                                                       |
| auto                                                  |                        |                                       | stack is empty. Branch to the routine                                                                                                                                                                                  |
| increment/                                            | 3.6                    |                                       | EMPTYERROR for appropriate action.                                                                                                                                                                                     |
| decrement                                             | Move                   | (SP)+, ITEM                           | Otherwise, pop the stack top element in memory                                                                                                                                                                         |
| addressing mode)                                      |                        |                                       | location ITEM onto the stack and increment the                                                                                                                                                                         |
| Or                                                    |                        |                                       | stack pointer (SP) appropriately.                                                                                                                                                                                      |
| OI                                                    |                        |                                       |                                                                                                                                                                                                                        |
| Name of                                               |                        |                                       |                                                                                                                                                                                                                        |
| Name of Routine                                       | Asse                   | mble Language                         | Remarks/ Actions of Assemble instructions                                                                                                                                                                              |
|                                                       | <u>Asse</u><br>Compare | mble Language<br>#2000, SP            | Remarks/ Actions of Assemble instructions  Check to see if the stack pointer contains an                                                                                                                               |
| Routine                                               | Compare                | <del></del>                           |                                                                                                                                                                                                                        |
| Routine<br>SAFEPOP                                    | Compare                | #2000, SP                             | Check to see if the stack pointer contains an address value greater than 2000. If it does, the stack is empty. Branch to the routine                                                                                   |
| Routine SAFEPOP (If it does not allow auto            | Compare<br>Branch > 0  | #2000, SP<br>EMPTYERROR               | Check to see if the stack pointer contains an address value greater than 2000. If it does, the stack is empty. Branch to the routine EMPTYERROR for appropriate action.                                                |
| Routine SAFEPOP (If it does not allow auto increment/ | Compare<br>Branch > 0  | #2000, SP<br>EMPTYERROR<br>(SP), ITEM | Check to see if the stack pointer contains an address value greater than 2000. If it does, the stack is empty. Branch to the routine EMPTYERROR for appropriate action. Otherwise, pop the stack top element in memory |
| Routine SAFEPOP (If it does not allow auto            | Compare<br>Branch > 0  | #2000, SP<br>EMPTYERROR               | Check to see if the stack pointer contains an address value greater than 2000. If it does, the stack is empty. Branch to the routine EMPTYERROR for appropriate action.                                                |

24. Suppose that a stack runs from location 1500 (BOTTOM) to no further than location 2000 (TOP) and each stack word consumes 4 bytes and machine is byte addressable. The stack pointer is loaded initially with the address value 1496. Write a routine for both PUSH and POP operation. Answer:

| <u>Name of</u><br><u>Routine</u>                                         | Assen                 | nble Language                    | Remarks/ Actions of Assemble instructions                                                                                                                                                                                    |
|--------------------------------------------------------------------------|-----------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAFEPUSH                                                                 | Compare               | #2000, SP                        | Check to see if the stack pointer contains an                                                                                                                                                                                |
| (If it allows                                                            | Branch ≥ 0            | FULLERROR                        | address value equals to or less than 1500. If it                                                                                                                                                                             |
| auto                                                                     |                       |                                  | does, the stack is full. Branch to the routine                                                                                                                                                                               |
| increment/                                                               |                       | NEWWEN ( (CD)                    | FULLERROR for appropriate action.                                                                                                                                                                                            |
| decrement                                                                | Move                  | NEWITEM, $+(SP)$                 | Otherwise, increment the stack pointer and push                                                                                                                                                                              |
| addressing                                                               |                       |                                  | the element in memory location NEWITEM onto the stack.                                                                                                                                                                       |
| mode)<br>Or                                                              |                       |                                  | the stack.                                                                                                                                                                                                                   |
|                                                                          |                       |                                  |                                                                                                                                                                                                                              |
|                                                                          |                       |                                  |                                                                                                                                                                                                                              |
| Name of Routine                                                          | Assen                 | nble Language                    | Remarks/ Actions of Assemble instructions                                                                                                                                                                                    |
| Name of                                                                  | Assen Compare         | nble Language<br>#2000, SP       | Remarks/ Actions of Assemble instructions  Check to see if the stack pointer contains an                                                                                                                                     |
| Name of Routine                                                          | Compare               |                                  |                                                                                                                                                                                                                              |
| Name of Routine SAFEPUSH                                                 | Compare               | #2000, SP                        | Check to see if the stack pointer contains an address value equals to or less than 1500. If it does, the stack is full. Branch to the routine                                                                                |
| Name of Routine SAFEPUSH (If it does not                                 | Compare               | #2000, SP                        | Check to see if the stack pointer contains an address value equals to or less than 1500. If it does, the stack is full. Branch to the routine FULLERROR for appropriate action.                                              |
| Name of Routine SAFEPUSH (If it does not allow auto increment/ decrement | Compare Branch ≥ 0    | #2000, SP<br>FULLERROR<br>#4, SP | Check to see if the stack pointer contains an address value equals to or less than 1500. If it does, the stack is full. Branch to the routine FULLERROR for appropriate action.  Otherwise, increment the stack pointer (SP) |
| Name of Routine SAFEPUSH (If it does not allow auto increment/           | Compare<br>Branch ≥ 0 | #2000, SP<br>FULLERROR           | Check to see if the stack pointer contains an address value equals to or less than 1500. If it does, the stack is full. Branch to the routine FULLERROR for appropriate action.                                              |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

...

| Name of Routine                             | Assen | nble Language           | Remarks/ Actions of Assemble instructions                                                                                                                               |
|---------------------------------------------|-------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAFEPOP<br>(If it allows auto increment/    | 1     | #1500, SP<br>EMPTYERROR | Check to see if the stack pointer contains an address value greater than 2000. If it does, the stack is empty. Branch to the routine EMPTYERROR for appropriate action. |
| decrement<br>addressing<br>mode)            | Move  | (SP)-, ITEM             | Otherwise, pop the stack top element in memory location ITEM onto the stack and decrement the stack pointer (SP) appropriately.                                         |
| Or  Name of  Routine                        | Assen | nble Language           | Remarks/ Actions of Assemble instructions                                                                                                                               |
| SAFEPOP<br>(If it does<br>not allow<br>auto | 1     | #1500, SP<br>EMPTYERROR | Check to see if the stack pointer contains an address value greater than 2000. If it does, the stack is empty. Branch to the routine EMPTYERROR for appropriate action. |

- 25. Register R5 is used in a program to point to the top of a stack. Assume that the stack address space ranges from 2000 to 1500 and each stack word consumes 4 bytes and machine is byte addressable. Write a sequence of instructions using the Index, Autoincrement, and Autodecrement addressing modes to perform each of the following tasks:
  - a) Pop the top two items off the stack, add them, and then push the result onto the stack.
  - b) Copy the fifth item from the top into register R3.

(SP), ITEM

#4, SP

c) Remove the top ten items from the stack.

[CO/Hamacher Book/5th Ed/Exercise/2.17/Page-100]

Otherwise, pop the stack top element in memory

location ITEM onto the stack and decrement the

stack pointer (SP) appropriately.

#### **Answer:**

increment/

decrement

addressing mode)

Move

Sub

Here, register R5 is used as the stack pointer (SP).

a) Pop the top two items off the stack, add them, and then push the result onto the stack.

Move (R5)+, R0 Add (R5)+, R0 Move R0, -(R5)

b) Copy the fifth item from the top into register R3.

Move 16(R5), R3

c) Remove the top ten items from the stack.

Add #40, R5



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

DOS:Dt.14.02.2020

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020

26. Given the following program fragment

| Main Program          | First Su       | First Subroutine  |                | Second Subroutine            |  |
|-----------------------|----------------|-------------------|----------------|------------------------------|--|
| 2000 ADD R1, R2       | <b>3000 SU</b> | B1 MOV R1,R2      | <b>4000 SU</b> | <b>B2 SUB R6</b> , <b>R1</b> |  |
| 2004 XOR R3, R4       | 3004           | <b>ADD R5, R1</b> | 4008           | <b>XOR R1, R5</b>            |  |
| <b>2008 CALL SUB1</b> | 3008           | CALL SUB2         | 4012           | <b>RETURN</b>                |  |
| 2012 CUD D4 D5        | 2012           | DETIDN            |                |                              |  |

2012 SUB R4, R5 3012 RETURN

Initially the stack pointer SP contains 5000.

What are the content of PC, SP, and the top of the stack?

- i) After the subroutine call instruction is executed in the main program?
- ii) After the subroutine call instruction is executed in the subroutine SUB1?
- iii) After the return from SUB2 subroutine?

#### **Answer:**







Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar

**SPRING 2020** COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

4TH Section: **IT7. IT8** Faculty: **Prof. Anil Kumar Swain** Sem:

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

| <b>Explanation</b>                               |  |  |
|--------------------------------------------------|--|--|
| Just after the start of execution of             |  |  |
| 3008 CALL SUB2,                                  |  |  |
| the address 3012 that is the address of next     |  |  |
| instruction is pushed in to the stack instead of |  |  |
| saving it in PC, as the instruction is a sub     |  |  |
| routine call. The PC is stored as the SUB2       |  |  |
| address. So, the content of                      |  |  |
|                                                  |  |  |

SP=4992

Top of Stack=[SP]=3012 PC=4000

Just after the execution of 4012 RETURN, the stacktop address is popped and stored in

PC that is PC=3012, the address of next instruction to be resumed for execution. So, the content of

SP=4996

Top of Stack=[SP]=2012

PC=3012

# **Single Bus Organisation**

27. Draw the diagram for single bus organisation of the datatpath inside a processor and explain the functionality of each of its components in one or two lines.

Answer:

Refer page no.413 of CO Book by Carl Hammacher, 5th ed.

28. Why is the Wait-for-Memory-Function-Completed (WMFC) step needed when reading from or waiting to the main memory.

[CO/Hamacher Book/5th Ed/Exercise/7.1/Page-446]

#### **Answer:**

The WMFC step is needed to synchronize the operation of the processor and the .main memory

29. Draw the diagram for the connection and control signals for register MDR.

#### **Answer:**

Refer page no.418 of CO Book by Carl Hammacher, 5th ed.

- 30. Write the sequence of control steps required for the single bus structure for each of the following instructions.
  - a) Add R3, R1
  - b) Add (R3), R1
  - c) Add 10(R3), R1

#### Answer:

#### Add R3, R1

|    | Sequence of control steps               | Explanation |
|----|-----------------------------------------|-------------|
| 1. | PCout, MARin, Read, Select4, Add, Zin   |             |
| 2. | Zout, PCin, Yin, WMFC                   |             |
| 3. | MDRout, IRin                            |             |
| 4. | R3out, Yin                              |             |
| 5. | R1out, Select <mark>Y</mark> , Add, Zin |             |
| 6. | Zout, R1in, End                         |             |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

### Add (R3), R1

|    | Sequence of control steps             | Explanation |
|----|---------------------------------------|-------------|
| 1. | PCout, MARin, Read, Select4, Add, Zin |             |
| 2. | Zout, PCin, Yin, WMFC                 |             |
| 3. | MDRout, IRin                          |             |
| 4. | R3out, MARin, Read                    |             |
| 5. | R1out, Yin, WMFC                      |             |
| 6. | MDRout, SelectY, Add, Zin             |             |
| 7. | Zout, R1in, End                       |             |

### Add 10(R3), R1

|    | Sequence of control steps             | Explanation |
|----|---------------------------------------|-------------|
| 1. | PCout, MARin, Read, Select4, Add, Zin | •           |
| 2. | Zout, PCin, Yin, WMFC                 |             |
| 3. | MDRout, IRin                          |             |
| 4. | Offset field of IRout, Yin            |             |
| 5. | R3out, Select Y, Add, Zin             |             |
| 6. | Zout, MARin, Read                     |             |
| 7. | R1out, Yin, WMFC                      |             |
| 8. | MDRout, Select Y, Add, Zin            |             |
| 9. | Zout, R1in, end                       |             |

- 31. Write the sequence of control steps required for the single bus structure for each of the following instructions.
  - a) Jump L1
  - b) Branch < 0 Label 1
  - c) Add -(R3), R1

### **Answer:**

# Jump L1

(Uncondotional Jump)

|    | Sequence of control steps              | Explanation |
|----|----------------------------------------|-------------|
| 1. | PCout, MARin, Read, Select 4, Add, Zin |             |
| 2. | Zout, PCin, Yin, WMFC                  |             |
| 3. | MDRout, IRin                           |             |
| 4. | Offset-field-of-IRout, Add, Zin        |             |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

| Ser  | m:   | 4TH S      | ection: | IT7, IT8 | Fac | culty: | Prof. Anil Kumar Swain |
|------|------|------------|---------|----------|-----|--------|------------------------|
| DOA: | Dt.0 | 3.02.2020  |         |          |     |        | DOS:Dt.14.02.2020      |
|      | 5.   | Zout, PCir | , End   |          |     |        |                        |

# Branch < 0 Label1 (Condtional Jump)

|    | (Conditional value)                     |             |  |  |
|----|-----------------------------------------|-------------|--|--|
|    | Sequence of control steps               | Explanation |  |  |
| 1. | PCout, MARin, Read, Select 4, Add, Zin  |             |  |  |
| 2. | Zout, PCin, Yin, WMFC                   |             |  |  |
| 3. | MDRout, IRin                            |             |  |  |
| 4. | Offset-field-of-IRout, Add, Zin if N=0, |             |  |  |
|    | then End                                |             |  |  |
| 5. | Zout, PCin, End                         |             |  |  |

### Add -(R3), R1

|    | Sequence of control steps              | Explanation |
|----|----------------------------------------|-------------|
| 1. | PCout, MARin, Read, Select 4, Add, Zin |             |
| 2. | Zout, PCin, Yin, WMFC                  |             |
| 3. | MDRout, IRin                           |             |
| 4. | R3out, Select4, Sub, Zin               |             |
| 5. | Zout, MARin, Read                      |             |
| 6. | R1out, Yin, WMFC                       |             |
| 7. | MDRout, Select Y, Add, Zin             |             |
| 8. | Zout, R1in, end                        |             |

- 32. Write the sequence of control steps required for the single bus structure for each of the following instructions.
  - a) Add the (immediate) number NUM to register R1
  - b) Add the contents of memory location NUM to register R1
  - c) Add the content of memory location whose address is at memory location NUM to register R1.

Assume that each instruction consists of two words. The first word specifies the operation and the addressing mode and the second word contains the number NUM.

### **Answer:**

(Add the (immediate) number NUM to register R1)

| Sequence of control steps                | Explanation |
|------------------------------------------|-------------|
| 1. PCout, MARin, Read, Select4, Add, Zin |             |
| 2. Zout, PCin, Yin, WMFC                 |             |
| 3. MDRout, IRin                          |             |
| 4. PCout, MARin, Read, Select4, Add, Zin |             |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

# Computer Organisation & Architecture Home Assignment Solution Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

 Sem:
 4TH
 Section:
 IT7, IT8
 Faculty:
 Prof. Anil Kumar Swain

 DOA:
 Dt.03.02.2020
 DOS:Dt.14.02.2020

 5.
 Zout, PCin, Yin
 6.
 R1out, Yin, WMFC

 7.
 MDRout, SelectY, Add, Zin

 8.
 Zout, R1in, End

(Add the contents of memory location NUM to register R1)

| Sequence of control steps                | Explanation |
|------------------------------------------|-------------|
| 1. PCout, MARin, Read, Select4, Add, Zin |             |
| 2. Zout, PCin, Yin, WMFC                 |             |
| 3. MDRout, IRin                          |             |
| 4. PCout, MARin, Read, Select4, Add, Zin |             |
| 5. Zout, PCin, WMFC                      |             |
| 6. MDRout, MARin, Read                   |             |
| 7. R1out, Yin, WMFC                      |             |
| 8. MDRout, Add, Zin                      |             |
| 9. Zout, R1in, End                       |             |

(Add the content of memory location whose address is at memory location NUM to register R1.)

| Sequence of control steps                | Explanation |
|------------------------------------------|-------------|
| 1. PCout, MARin, Read, Select4, Add, Zin |             |
| 2. Zout, PCin, Yin, WMFC                 |             |
| 3. MDRout, IRin                          |             |
| 4. PCout, MARin, Read, Select4, Add, Zin |             |
| 5. Zout, PCin, WMFC                      |             |
| 6. MDRout, MARin, Read, WMFC             |             |
| 7. MDRout, MARin, Read                   |             |
| 8. R1out, Yin, WMFC                      |             |
| 9. MDRout, Add, Zin                      |             |
| 10. Zout, R1in, End                      |             |

33. Draw the diagram for the three bus organisation of the datatpath inside a processor and explain the functionality of each of its components in one or two lines.

#### Answer:

Refer page no.423 of CO Book by Carl Hammacher, 5th ed.



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020

DOS:Dt.14.02.2020

34. Explain the working principle of Hardwired control unit design along with neat diagram. Explain its advantages and disadvantages.

**Answer:** 

Refer page no.425 of CO Book by Carl Hammacher, 5th ed.

35. Write the control sequence for the instruction Add R1, R2, R3 for the three bus organisation.

Answer:

### Add R4, R5, R6

| Sequence of control steps                  | Explanation |
|--------------------------------------------|-------------|
| 1. PCout, R=B, MARin, Read, IncPC          |             |
| 2. WMFC                                    |             |
| 3. MDRoutB, R=B, IRin                      |             |
| 4. R4outA, R5outB, SelectA, Add, R6in, End |             |

36. Draw and explain the working principle of microprogrammed control unit.

#### Answer

Refer page no.429 of CO Book by Carl Hammacher, 5th ed.



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020

DOS:Dt.14.02.2020

https://www.geeksforgeeks.org/computer-organization-and-architecture-gq/

Assume one has written a program in C and compiled it with two different compilers. Each compiler generated the following numbers of instructions of each of three instruction types, I1, I2 and I2, for this program (expressed in millions, M):

I1 I2 I3

Compiler-1 5M 1M 1M

Compiler-2 10M 1M 1M

Let f be 1GHz. An instruction of type I1, I2, and I3 takes 1, 2 and 3 clock cycles, respectively. Find out the execution times

37. How many times a subroutine should be called so that the stack becomes full, Assume that the stack address space ranges from 2000 to 1600 and each stack word consumes 4 bytes and machine is byte addressable. [Note: No parameter, return value, registers, local variables are stored in the stack due to subroutine call]

**Answer:** 

2000 down to 1600 = 2000-1600+1=401

100

38. What is stack frame? Give an example of stack frame for nested subroutine.



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020 DOS:Dt.14.02.2020

**Answer:** 

2000 down to 1600 = 2000-1600+1=401

39. Consider a computer that has a byte-addressable memory organized in 32-bit words. A program reads ASCII characters entered at a keyboard and stores them in successive byte locations, starting at location 5000. Show the contents of the two memory words at locations 5000 and 5004 after the name "Computer" has been entered. Solve this problem for both big-endian and little-endian scheme.

The ASCII values: C=67=43H, o=111=6FH, m=109=6DH, p=112=70H, u=117=75H, t=116=74H, e=101=65H, r=114=72H

### Content of Memory as character in Byte Addressable memory

| Big-Endian Format           |                                            |                  |                  | Little-E         | Little-Endian Format        |                             |                  |                  |                  |
|-----------------------------|--------------------------------------------|------------------|------------------|------------------|-----------------------------|-----------------------------|------------------|------------------|------------------|
| (Memor                      | (Memory Conent - Character)                |                  |                  |                  | (Memor                      | (Memory Conent - Character) |                  |                  |                  |
|                             |                                            |                  |                  |                  | _                           |                             |                  |                  |                  |
| 4092                        |                                            |                  |                  |                  | 4092                        |                             |                  |                  |                  |
| 4096                        | 4096                                       | 4097             | 4098             | 4099             | 4096                        | 4096                        | 4097             | 4098             | 4099             |
| 5000                        | <b>C</b> 5000                              | <b>o</b><br>5001 | <b>m</b><br>5002 | <b>p</b> 5003    | 5000                        | <b>p</b> 5000               | <b>m</b><br>5001 | <b>o</b><br>5001 | <b>C</b> 5003    |
| 5004                        | <b>u</b><br>5004                           | <b>t</b> 5005    | <b>e</b><br>5006 | <b>r</b><br>5007 | 5004                        | <b>r</b><br>5004            | <b>e</b><br>5005 | <b>t</b> 5006    | <b>u</b><br>5007 |
| 5008                        | 5008                                       | 5009             | 5010             | 5011             | 5008                        | 5018                        | 5009             | 5010             | 5011             |
| 5012                        |                                            |                  |                  |                  | 5012                        |                             |                  |                  |                  |
|                             |                                            |                  |                  |                  | _                           |                             |                  |                  |                  |
|                             |                                            |                  |                  |                  |                             |                             |                  |                  |                  |
| So, the                     | So, the two words at 5000 and 5004 will be |                  |                  |                  | e So, the                   | two wo                      | ords at 50       | 00 and 5         | 004 will be      |
| Comp and uter respectively. |                                            |                  |                  | Comp ar          | Comp and uter respectively. |                             |                  |                  |                  |

### Content of Memory as Hexa Decimal in Byte Addressable memory

| Big-End                        | lian Forr        | nat              |                  |                  | Little-Endian Format           |                  |                  |                  |                  |
|--------------------------------|------------------|------------------|------------------|------------------|--------------------------------|------------------|------------------|------------------|------------------|
| (Memory Conent - Hexa Decimal) |                  |                  |                  |                  | (Memory Conent - Hexa Deciaml) |                  |                  |                  |                  |
|                                |                  |                  |                  |                  | _                              |                  |                  |                  |                  |
| 4092                           |                  |                  |                  |                  | 4092                           |                  |                  |                  |                  |
| 4096                           | 4096             | 4097             | 4098             | 4099             | 4096                           | 4099             | 4098             | 4097             | 4096             |
| 5000                           | <b>C</b> 5000    | <b>o</b><br>5001 | <b>m</b><br>5002 | <b>p</b> 5003    | 5000                           | <b>p</b> 5003    | <b>m</b><br>5002 | <b>o</b><br>5001 | <b>C</b> 5000    |
| 5004                           | <b>u</b><br>5004 | <b>t</b> 5005    | <b>e</b><br>5006 | <b>r</b><br>5007 | 5004                           | <b>r</b><br>5007 | <b>e</b> 5006    | <b>t</b> 5005    | <b>u</b><br>5004 |
| 5008                           | 5008             | 5009             | 5010             | 5011             | 5008                           | 5011             | 5010             | 5009             | 5008             |
| 5012                           |                  |                  |                  |                  | 5012                           |                  |                  |                  |                  |
|                                |                  |                  |                  |                  | _                              |                  |                  |                  |                  |
|                                |                  |                  |                  |                  |                                |                  |                  |                  |                  |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

## **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020

DOS:Dt.14.02.2020

The ASCII values: J=74=4AH, o=111=6FH, h=104=68H, n=110=6EH, s=115=73H, o=111=6FH n=110=6EH

- **40.** Write a program to evaluate the given arithmetic expression Z = (R + P) \* E + K \* B L / G S
  - ii) Using a general register computer with two address and three address instructions.
  - iii) Using an accumulator type computer with one address instructions.
  - iv) Using a stack organized computer with zero-address operation instructions.
  - v) Using RISC computer instruction format.

#### **Answer:**

| i) Three Address | ii) Two Address | iii) One Address | iv) Zero Instruction |  |
|------------------|-----------------|------------------|----------------------|--|
| ADD R, P, R1     | MOV P, R1       | LOAD P           | PUSH R               |  |
| MUL R1, E, R2    | ADD R, R1       | ADD R            | PUSH P               |  |
| MUL K, B, R3     | MUL E, R1       | MUL E            | ADD                  |  |
| ADD R2, R3, R4   | MOV B, R2       | STORE X          | PUSH E               |  |
| DIV L, G, R5     | MUL K, R2       | LOAD B           | MUL                  |  |
| SUB R4, R5,      | ADD R1, R2      | MUL K            | PUSH K               |  |
| R6               | MOV G, R3       | ADD X            | PUSH B               |  |
| SUB R6, S, Z     | DIV L, R3       | STORE Y          | MUL                  |  |
|                  | SUB R2, R3      | LOAD G           | ADD                  |  |
|                  | MOV S, R4       | DIV L            | PUSH L               |  |
|                  | SUB R3, R4      | SUB Y            | PUSH G               |  |
|                  | MOV R4, Z       | STORE W          | DIV                  |  |
|                  |                 | LOAD S           | SUB                  |  |
|                  |                 | SUB W            | PUSH S               |  |
|                  |                 | STORE Z          | SUB                  |  |
|                  |                 |                  | POP                  |  |

| RISC Instructions |
|-------------------|
| LOAD R, R1        |
| LOAD P, R2        |
| LOAD E, R4        |
| LOAD K, R6        |
| LOAD B, R7        |
| LOAD L, R10       |
| LOAD G, R11       |
| LOAD S, R14       |
| ADD R1, R2, R3    |
| MUL R3, R4, R5    |
| MUL R6, R7, R8    |
| ADD R5, R8, R9    |
| DIV R10, R11, R12 |
| SUB R9, R12, R13  |



Kalinga Institute of Industrial Technology (KIIT), Deemed to be University, Bhubaneswar SPRING 2020 COA-HA SET-1

DOS:Dt.14.02.2020

### **Computer Organisation & Architecture Home Assignment Solution**

Sem: 4TH Section: IT7, IT8 Faculty: Prof. Anil Kumar Swain

DOA: Dt.03.02.2020

SUB R13, R14, R15 STORE R15, Z

- 41. The content of register R1 is 10110110. What will be the decimal value after execution of the following individual instructions. Assume the number is represented in 2's complement format.
  - a) LShiftL #2, R1
  - b) LShiftL +3, R1
  - c) LShiftR #2, R1
  - d) LShiftR +3, R1
  - e) AShiftL #2, R1
  - f) AShiftL +3, R1
  - g) AShiftR #2, R1
  - h) AShiftR +3, R1
- 42. Consider a computer that has a byte-addressable memory organized in 32-bit words. A program reads ASCII characters entered at a keyboard and stores them in successive byte locations, starting at location 5000. Show the contents of the two memory words at locations 1000 and 1004 after the name "Johnson" has been entered. Solve this problem for both big-endian and little-endian scheme.

The ASCII values: J=74=4AH, o=111=6FH, h=104=68H, n=110=6EH, s=115=73H, o=111=6FH

n=110=6EH

Answer:

**Big-Endian scheme** 

**Content at memory location 1000**: J o h n **Content at memory location 1000**: 4A 6F 68 6E

Content at memory location 1004: 73 6F 6E XX (Byte 1007 is shown as XX)

Content at memory location 1004: s o n XX

### Little-Endian scheme

Content at memory location 1000: n h o J Content at memory location 1000: 6E 68 6F 4A

Content at memory location 1004: XX 6E 6F 73 (Byte 1007 is shown as XX)

Content at memory location 1004: XX n o s

http://teaching.idallen.com/cst8281/10w/notes/110 byte order endian.html

https://www.youtube.com/watch?v=9Rgnl4o0Vv8